// pages/profile/index.ts
Page({
  /**
   * 页面的初始数据
   */
  data: {
    // 用户的信息
    // nickName: '',
    // avatar: ''
    userInfo: {}
  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow () {
    this.setData({
      userInfo: wx.getStorageSync('userInfo')
    })
  },

  // 获取用户头像
  getAvatar (e) {
    // console.log(e.detail.avatarUrl)
    const app = getApp()

    wx.uploadFile({
      url: 'https://live-api.itheima.net/upload',
      filePath: e.detail.avatarUrl,
      header: {
        Authorization: app.token
      },
      name: 'file',
      formData: {
        type: 'avatar'
      },
      success: res => {
        // console.log(Json.parse(res.data).data.url)
        const imgUrl = JSON.parse(res.data).data.url
        this.setData({
          'userInfo.avatar': imgUrl
        })
      }
    })
  },

  // 获取用户输入的昵称
  async getNickName (e) {
    // console.log(e.detail.value)
    if (!e.detail.value.trim()) return
    const res = await wx.$http.put('/userInfo', {
      nickName: e.detail.value.trim()
    })
    if (res.code !== 10000) return wx.$utils.toast('保存昵称失败')
    this.setData({
      'userInfo.nickName': e.detail.value.trim()
    })
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad () {},

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady () {},

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide () {},

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload () {},

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh () {},

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom () {},

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage () {}
})
